<template>
  <view>
    <!-- 收货地址组件 -->
    <!-- 选择收货地址的盒子开始 -->
    <!-- v-if="JSON.stringify(address) === '{}'"如果转化以后是个空对象就展示`选择收货地址的盒子`否则就展示`收货信息的盒子` -->
     <view class="address-choose-box" v-if="JSON.stringify(address) === '{}'">
        <button type="primary" size="mini" class="btnChooseAddress" @click="chooseAddress">请选择收货地址+</button>
      </view>
    <!-- 选择收货地址的盒子结束 -->
    
    <!-- 渲染收货信息的盒子开始 -->
     <!-- <view class="address-info-box" v-else @click="rechooseAddress"> -->
     <view class="address-info-box" v-else @click="chooseAddress">
        <view class="row1">
          <view class="row1-left">
            <view class="username">收货人：<text>{{address.userName}}</text></view>
          </view>
          <view class="row1-right">
            <view class="phone">电话：<text>{{address.telNumber}}</text></view>
            <uni-icons type="arrowright" size="16"></uni-icons>
          </view>
        </view>
        <view class="row2">
          <view class="row2-left">收货地址：</view>
          <!-- {{addstr}}计算属性 -->
          <view class="row2-right">{{addstr}} </view>
        </view>
      </view>
    <!-- 渲染收货信息的盒子结束 -->
    
    <!-- 底部的边框线开始 -->
      <image src="/static/cart_border@2x.png" class="address-border"></image>
    <!-- 底部的边框线结束 -->
  </view>
</template>

<script>
   // vuex 提供的 address 计算属性 替代 data 中定义的本地 address 对象
  // 按需导入 mapState 和 mapMutations 这两个辅助函数
  import { mapState, mapMutations,mapGetters } from 'vuex'
  export default {
    name:"my-address",
    data() {
      return {
        // 收货地址
        // 注释掉下面的 address 对象，使用vuex中的address替代之
        // address: {
        // },
        
      };
    },
    computed:{
      // m_user 模块中的 address 对象映射当前组件中使用，代替 data 中 address 对象
       ...mapState('m_user', ['address']),
       // 收货详细地址的计算属性
       // addstr(){
       //   // 先判断this.address是否有数据
       //   if (!this.address.provinceName) return ''
       //   // 拼接 省，市，区，详细地址 的字符串并返回给用户
       //   return this.address.provinceName + this.address.cityName + this.address.countyName + this.address.detailInfo
       // }
       // 将 m_user 模块中的计算属性addstr 映射到当前组件中使用
       ...mapGetters('m_user', ['addstr']),
    },
    methods:{
      // 把 m_user 模块中的 updateAddress 函数映射到当前组件(修改/保存到vuex中address方法)
      ...mapMutations('m_user', ['updateAddress']),
       // 选择收货地址
         // chooseAddress() {
         async chooseAddress() {
          console.log(111);
           // 1. 调用小程序提供的 chooseAddress() 方法，即可使用选择收货地址的功能
           //返回值是一个数组：第 1 项为错误对象；第 2 项为成功之后的收货地址对象
          const [err, succ] = await uni.chooseAddress().catch(err => err)
          // 2. 用户成功的选择了收货地址
           if (err === null && succ.errMsg === 'chooseAddress:ok') {
               // 为 data 里面的收货地址对象赋值
               // this.address=succ
               // 调用 Store 中提供的 updateAddress 方法，将 address 保存到 Store 里面
               this.updateAddress(succ)
               console.log('选择收货信息',this.address);
          }

          // const add={
          //     cityName:'广州市',
          //     countyName:'海珠区',
          //     detailInfo:'新港中路397号',
          //     nationalCode:'510000',
          //     postallCode:'510000',
          //     provinceName:'广东省',
          //     telNumber:'020-81167888',
          //     userName:'张三',  
          // }
          // 调用 Store 中提供的 updateAddress 方法，将 address 保存到 Store 里面
          // this.updateAddress(add)
          
          console.log('授权与否',err);
          // 用户没有授权
          // 在模拟器和安卓真机上，错误消息 err.errMsg 的值为 chooseAddress:fail auth deny
          // 在 iPhone 真机上，错误消息 err.errMsg 的值为 chooseAddress:fail authorize no response
          // if (err && err.errMsg === 'chooseAddress:fail auth deny') {
          if (err && (err.errMsg === 'chooseAddress:fail auth deny' || err.errMsg === 'chooseAddress:fail authorize no response')) {
              this.reAuth() // 调用 this.reAuth() 方法，向用户重新发起授权申请
            }
          
        },
        // 重新选择地址
        // rechooseAddress(){
        //   const add2={
        //       cityName:'广州市',
        //       countyName:'海珠区',
        //       detailInfo:'新港中路397号',
        //       nationalCode:'510000',
        //       postallCode:'510000',
        //       provinceName:'广东省',
        //       telNumber:'020-81167888',
        //       //Math.random() 生成随机数字, eg: 0.123456
        //       //.toString(36) 转化成36进制 : "0.4fzyo82mvyr"
        //       //.slice(-6); 截取最后6位 : "yo82mv"
        //       userName:'张三'+Math.random().toString(36).slice(-6),  
        //   }
        //   // 调用 Store 中提供的 updateAddress 方法，将 address 保存到 Store 里面
        //   this.updateAddress(add2)
          
        // },
        
       // 调用此方法，重新发起收货地址的授权
       async reAuth() {
         console.log('调用与否');
         // 3.1 提示用户对地址进行授权
         const [err2, confirmResult] = await uni.showModal({
           content: '检测到您没打开地址权限，是否去设置打开？',
           confirmText: "确认",
           cancelText: "取消",
         })
       
         // 3.2 如果弹框异常，则直接退出
         if (err2) return
       
         // 3.3 如果用户点击了 “取消” 按钮，则提示用户 “您取消了地址授权！”
         if (confirmResult.cancel) return uni.$showMsg('您取消了地址授权！')
       
         // 3.4 如果用户点击了 “确认” 按钮，则调用 uni.openSetting() 方法进入授权页面，让用户重新进行授权
         if (confirmResult.confirm) return uni.openSetting({
           // 3.4.1 授权结束，需要对授权的结果做进一步判断
           success: (settingResult) => {
             // 3.4.2 地址授权的值等于 true，提示用户 “授权成功”
             if (settingResult.authSetting['scope.address']) return uni.$showMsg('授权成功！请选择地址')
             // 3.4.3 地址授权的值等于 false，提示用户 “您取消了地址授权”
             if (!settingResult.authSetting['scope.address']) return uni.$showMsg('您取消了地址授权！')
           }
         })
       },
        
    }
  }
</script>

<style lang="scss">
  // 底部边框线的样式开始
  .address-border {
    display: block;
    width: 100%;
    height: 5px;
  }
  // 底部边框线的样式结束
  
  // 选择收货地址的盒子开始
  .address-choose-box {
    height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  // 选择收货地址的盒子结束
  
  // 渲染收货信息的盒子开始
  .address-info-box {
    font-size: 12px;
    height: 90px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 5px;
  
    // 第一行
    .row1 {
      display: flex;
      justify-content: space-between;
  
      .row1-right {
        display: flex;
        align-items: center;
  
        .phone {
          margin-right: 5px;
        }
      }
    }
  
    // 第二行
    .row2 {
      display: flex;
      align-items: center;
      margin-top: 10px;
  
      .row2-left {
        white-space: nowrap;
      }
    }
  }
  // 渲染收货信息的盒子结束

</style>